

Alarm Clock Project

SILICON

www.maven-silicon.com

SILICON

SILICON



# **Maven Silicon Confidential**

All the presentations, books, documents [hard copies and soft copies], labs and projects [Source Code] that you are using and developing as part of the training course are the proprietary work of Maven Silicon and it is fully protected under copyright and trade secret laws. You may not view, use, disclose, copy, or distribute the materials or any information except pursuant to a valid written license from Maven Silicon.













# **Table of Contents**

| larm Clock                        | 2.5     | ON |
|-----------------------------------|---------|----|
| Idi III Ciock                     | 027276  | 4  |
| ALARM CLOCK: LCD Display Driver   | 4000    | 7  |
| ALARM CLOCK: LCD Display Unit     |         | 9  |
| LARM CLOCK: The Alarm Register    |         |    |
| CON                               |         |    |
| ALARM CLOCK: Time Generator       |         | N  |
| ALARM CLOCK: Counter              | 0951210 | 14 |
| ALARM CLOCK: Key Register         | ( ) .   | 16 |
| ALARM CLOCK: Controller Unit      |         | 18 |
| ALARM CLOCK: Top Level RTL Module |         | 21 |
| - ON                              |         |    |





# **Alarm Clock**

A digital alarm clock displays time in the LCD display format.

## **Block Diagram**



#### I/O Ports:

- "clk" is a 256 Hz clock.
- "reset" is an asynchronous active high reset.
- "Key" is the four bits key input
- "alarm button" is an active high control signal for setting the Alarm Time
- "time button" is an active high control signal for setting the Current Time
- "sound alarm" is an active high output.
- "Display Time" are the outputs which display the values in LCD format.
- In "fast watch" mode clock runs faster by using second pulse as minute



This top level module has six sub-modules mentioned below

- 1. Time generator
- 2. Key register
- 3. Alarm register
- 4. Counter
- 5. Alarm controller
- 6. Display driver

All the above modules are sequential logics except the display driver, a combinational logic.





















# **ALARM CLOCK: LCD Display Driver**



"aclk\_lcd\_driver" is a combinational logic unit which displays the four bit binary values of the keys in the LCD format and it also generates the alarm sound signal.

## Functionality:

"show\_a" and "show\_new\_time" are active high control signals which control the display\_time.

- [show\_a = 1] AND [show\_new\_time = 0] => [ display\_time = alarm\_time ]
- [show\_a = 0] AND [show\_new\_time = 0] => [ display\_time = current\_time ]
- [show\_a = 0] AND [show\_new\_time = 1] => [ display\_time = key\_time ]

The inputs alarm\_time, current\_time and key use 4 bits BCD



LICON



The output display\_time uses 8bits equivalent LCD, as per the table shown below.

| BCD Value | LCD Value |  |
|-----------|-----------|--|
| 0000      | 8'h30     |  |
| 0001      | 8'h31     |  |
| 0010      | 8'h32     |  |
| 0011      | 8'h33     |  |
| 0100      | 8'h34     |  |
| 0101      | 8'h35     |  |
| 0110      | 8'h36     |  |
| -0111     | 8'h37     |  |
| 1000      | 8'h38     |  |
| 1001      | 8'h39     |  |

## **RTL Design Procedure:**

- [1] Naming Convention:
  - [A] Modules and Files

Module Name: aclk\_lcd\_driver

Test bench Name: tb\_aclk\_lcd\_driver

[B] Name the ports as per the block

[2] Verify the functionality of the RTL

[3] Synthesize the RTL

File Name: aclk\_lcd\_driver.v

File Name: tb\_aclk\_lcd\_driver.v





# **ALARM CLOCK: LCD Display Unit**



"aclk\_lcd\_display" is a display unit which displays all the digits MS\_HR, LS\_HR, MS\_MIN and LS\_MIN in the LCD format as shown below.

25 3 : 5 9 60

MS Hour LS Hour MS Minute LS Minute





# **RTL Design Procedure:**

[1] Naming Convention:

[A] Modules and Files

Module Name: aclk\_lcd\_display File Name: aclk\_lcd\_display.v

Test bench Name: tb\_aclk\_lcd\_display FileName: tb\_aclk\_lcd\_display.v

[B] Name the ports as per the block diagram

[2] Instantiate the display driver "aclk\_lcd\_driver" and create instance for each digit and implement this display unit.

[3] Verify the functionality of the RTL

[3] Synthesize the RTL







# **ALARM CLOCK: The Alarm Register**



# Functionality:

This alarm register is a sequential block which stores the values of alarm time values.

- [reset = 1] => All outputs become ZERO
- $[load_new_a = 1]$  AND  $[reset = 0] \Rightarrow$  All outputs get the value of all the inputs.
- $[load_new_a = 0]$  AND  $[reset = 0] \Rightarrow$  All outputs retain their previous value

#### **RTL Design Procedure:**

- [1] Naming Convention:
  - [A] Modules and Files

Module Name: aclk areg File Name: aclk areg.v Test bench Name: tb\_aclk\_areg File Name: tb\_aclk\_areg.v TLICON

- [B] Name the ports as per the block diagram
- [2] Verify the functionality of the RTL
- [3] Synthesize the RTL



# **ALARM CLOCK: Time Generator**



Time Generator is a sequential logic block which generates the one\_minute pulse for the counter that counts the minutes and hours.

## Functionality:

*dclk\_256* is the divided clock input. Time Generator generates the one\_minute and one\_second pulses based on the algorithm mentioned below.

For 256Hz clk 
$$\rightarrow$$
 one second = 256 cycles  $\rightarrow$  one minute = 256\*60 = 15360 cycles

 $15360_{10} = 1111000000000000_2$ 

- one\_second will be active high for one clock period, when the number of clock cycles
   = 256
- one\_minute will be active high for one clock period only when the number of clock cycles = 15360
- [fast\_watch=1] → [one\_minute = one\_second] Useful only for faster simulation.
- [reset\_count = 1] → All outputs reset to ZERO
- [reset = 1] → All outputs reset to ZERO





## **RTL Design Procedure:**

[1] Naming Convention:

[A] Modules and Files

Module Name: aclk\_timegen
Test bench Name: tb\_aclk\_timegen

File Name: aclk\_timegen.v File Name: tb\_aclk\_timegen.v

[B] Name the ports as per the block diagram

[2] Verify the functionality of the RTL

[3] Synthesize the RTL

SILICON



SILICON





# **ALARM CLOCK: Counter**



Counter is a sequential block which counts the minutes and hours based on the one\_minute pulse generated by the Time Generator.

## Functionality:

- [reset = 1]  $\rightarrow$  All the outputs reset to ZERO
- [load\_new\_c=1] AND [reset=0] → Counter is loaded with all the inputs new\_current\_time
- [load\_new\_c=0] AND [one\_minute=0] → Counter retains it's previous values
- load\_new\_c=0] AND [one\_minute=1] → Counter counts based on the counting algorithm





## **Counting Algorithm:**

- $[LS_MIN = 9] \rightarrow [LS_MIN = 0]$  AND  $[MS_MIN = MS_MIN + 1]$
- [MS\_MIN = 5] AND [LS\_MIN = 9]  $\rightarrow$  [MS\_MIN=0, LS\_MIN =0] AND [LS\_HR = LS\_HR+1]
- [LS\_HR=9 and MS\_MIN= 5 and LS\_MIN =9] →

  [ MS\_MIN=0, LS\_MIN=0, LS\_HR=0] AND [MS\_HR = MS\_HR+1]
- [MS\_HR=2 and LS\_HR =3 and MS\_MIN=5 and LS\_MIN =9] →

  [MS\_MIN=0, LS\_MIN=0, LS\_HR=0, MS\_HR=0]

## **RTL Design Procedure:**

- [1] Naming Convention:
  - [A] Modules and Files

Module Name: aclk\_counter File Name: aclk\_counter.v

Test bench Name: tb\_aclk\_counter FileName: tb\_aclk\_counter.v

- [B] Name the ports as per the block diagram
- [2] Verify the functionality of the RTL
- [3] Synthesize the RTL





#### **Display Patterns:**

1259

2590

59 09

9094

09 43

# **RTL Design Procedure:**

[1] Naming Convention:

[A] Modules and Files

Module Name: aclk\_keyreg
Test bench Name: tb\_aclk\_keyreg

[B] Name the ports as per the block diagram

[2] Verify the functionality of the RTL

[3] Synthesize the RTL

SILICON

File Name: aclk\_keyreg.v

FileName: tb\_aclk\_keyreg.v





# **ALARM CLOCK: Controller Unit**



This is a controller unit for the Alarm Clock. It generates various control signals which controls the other blocks, Key Reg, Display Driver and Time Generator.

#### Functionality:

#### **Setting Time Digits:**

0 to 9 are the valid keys to set the time value.

10 represents "No Key" – Means, the user is not pressing any keys. [Default value of the keypad output]

One has to press four keys to set all the digits MS\_HR, LS\_HR, MS\_MIN and LS\_MIN, by taking maximum 10 seconds for each key. If no keys are pressed within 10 seconds, the new value will be ignored and the display immediately returns to the current time.

The new values will be shifted through the digits MS\_HR, LS\_HR, MS\_MIN and LS\_MIN, from right to left, as shown below.

Current Time: 1 2 59 New Time: 0 9 43

#### **Display Patterns:**

1259

2590

59 09

9094

09 43

PEILICON



#### Setting new alarm time:

The user sets the alarm time as explained above and presses the alarm button. Now the clock considers the digits set by user for the alarm time. The display will show the alarm time.

#### Setting new time:

The user sets the alarm time as explained above and presses the time button. Now the clock considers the digits set by user for the current time. The display will show the new time.

#### **Displaying Alarm Time:**

Alarm Time is displayed when the user presses the alarm button, without pressing any other keys.

#### **Output Logic:**

[State = SHOW\_ALARM] => show\_a = 1'b1

## **RTL Design Procedure:**

[1] Naming Convention:

[A] Modules and Files

Module Name: aclk\_controller
Test bench Name: tb\_aclk\_controller

- [B] Name the ports as per the block diagram
- [2] Verify the functionality of the RTL
- [3] Synthesize the RTL

File Name: aclk\_controller.v FileName: tb\_aclk\_controller.v





## Controller - FSM





File Name: alarm\_clk\_rtl.v

FileName: tb\_alarm\_clk\_rtl.v



# **ALARM CLOCK: Top Level RTL Module**

# **RTL Design Procedure:**

[1] Naming Convention:

[A] Modules and Files

Module Name: alarm\_clk\_rtl
Test bench Name: tb\_alarm\_clk\_rtl

[B] Name the ports as per the block diagram

[2] Instantiate all the lower level modules and implement the top module, as per the architecture shown

in page 4.

[3] Write a testbench and verify the functionality of the RTL

[4] Synthesize the RTL



